草庐IT

c++ - 特化 std::make_shared

全部标签

c++ - Clang 无法识别 <algorithm> 中的 std::all_of

在我们的测试环境中编译时遇到了以下问题:尽管窗口已经在工作,但我们在Freebsd9上的构建失败并显示以下错误消息:error:nomembernamed'all_of'innamespace'std'鉴于我将-std=c++11添加到我们的Cmake标志中,我想知道为什么这不起作用。clangversion3.4(tags/RELEASE_34/final)Target:i386-portbld-freebsd9.1Threadmodel:posix函数如下#include...inlineboolis_positive_number(conststd::string&str){if

c++ - 是否可以将 WebRTC 浏览器转换为原生(C、C++ 或其他)?

我见过几个浏览器原生WebRTC应用程序的例子,比如将存储在服务器上的视频文件流式传输到一个或多个浏览器,但是有没有可能相反?IE。将网络摄像头从浏览器传输到用C、C++、Java或其他语言编写的服务器? 最佳答案 这是可能的。WebRTC使用开放标准通过网络传输内容。您可以在以下RFC中找到所有详细信息:http://tools.ietf.org/wg/rtcweb/如果您想编写自己的native应用程序来接收(甚至发送)WebRTC媒体,您可以从此处获取WebRTCnative代码:http://www.webrtc.org/w

c++ - 如何从 Clang 中的 CallExpr 获取函数指针的参数?

我正在尝试分析其中包含函数调用的C源代码。我能够使用下面的源代码分析正常的函数调用以毫无问题地获取它们的参数,其中ce是一个CallExpr对象:1.if(ce!=NULL){2.QualTypeq=ce->getType();3.constType*t=q.getTypePtrOrNull();4.5.if(t!=NULL){6.llvm::errs()isFunctionPointerType()isPointerType()getCalleeDecl();13.while(D->getPreviousDecl()!=NULL)14.D=D->getPreviousDecl();1

c++ - 为什么允许嵌套类模板的部分特化,而不允许完全特化?

templatestructA{templatestructB{};.templatestructC{};};templatetemplatestructA::B{};//error:enclosingclasstemplatesarenotexplicitlyspecializedtemplatetemplatestructA::C{};//ok那么,如果外部类也不是特化的,那么为什么不允许对内部嵌套类(或函数)进行显式特化呢?很奇怪,如果我只是部分通过简单地添加一个虚拟模板参数来专门化内部类,我就可以解决这个问题。使事情变得更丑陋和更复杂,但它有效。我会将完全特化视为部分特化的子集

c++ - 非命名空间范围内的显式特化

这个问题在这里已经有了答案:C++syntaxforexplicitspecializationofatemplatefunctioninatemplateclass?(9个回答)关闭8年前。templateclassCConstraint{public:CConstraint(){}virtual~CConstraint(){}templatevoidVerify(intposition,intconstraints[]){}templatevoidVerify(int,int[]){}};在g++下编译会出现以下错误:Explicitspecializationinnon-name

c++ - visual c++ 2013 是否有使用旧方言的选项(如 gcc 的 -std=c++98)?

我有一些代码可以在VisualC++2013中编译,但我被告知它不能在VC++2010中构建(因为它使用了微妙的c++11ism)。当然,我要做的是用两个编译器进行测试,但是......没有办法在VisualC++2013中关闭c++11并让它只接受c++08,正如我认为gcc的-std=c++98选项那样? 最佳答案 对于这种情况,唯一的方法是在项目->属性->常规中将PlatformToolset更改为VisualStudio2010(v100)。一旦你改变它,你将在VS2013下运行VC++2010编译器。

c++ - 释放存储在 std::queue 中的堆指针

考虑这段代码:classFoo;std:queueq;//allocateandaddobjectstothequeuefor(inti=0;i通过单步执行,我可以看到Foo析构函数在每个对象被删除时被调用,所以我希望进程内存使用量会随着每次删除发生而下降-但事实并非如此。在我的应用程序中,队列用于生产者/消费者线程,内存使用量一直在增长。我发现恢复内存的唯一方法是在我从队列中弹出所有项目时将队列交换为空队列:q.swap(std::queue());如果我使用vector而不是队列,删除存储的对象会立即降低进程内存使用量。任何人都可以解释为什么队列不是那样的吗?编辑以从评论中澄清:我

c++ - 如何在 rstudio 上为使用子目录内 src 文件夹中的 C/C++ 文件的包构建和加载共享库?

我有一个正在处理的R包,它包含在src文件夹下用C和C++编写的代码。目前,该包在Rstudio上编译和工作,因为它遵循默认目录结构。随着项目的构建,我希望能够在src下的子文件夹中组织我的代码。按照“编写R扩展”-在子目录下编译的指示,我创建了一个名为“test”(/src/test)的文件夹,其中现在包含我的所有文件(*.c、*.cpp、*.h)和像这样修改我的Makevars-SOURCES_C=$(wildcardtest/*.c)SOURCES_CPP=$(wildcardtest/*.cpp)PKG_CPPFLAGS=-I${R_HOME}/include-I.PKG_LI

c++ - std::basic_fstream::put() 无效

我有以下代码:#include#includeintmain(intargc,char*argv[]){if(argc!=2){std::cout"stream;stream.open(argv[1],std::fstream::out);stream.put('T');stream.put('E');stream.put('S');stream.put('T');stream.flush();stream.close();return0;}正在创建文件,但当我在编辑器中打开它时,里面什么也没有。我的编译器是gccversion4.8.2(Ubuntu4.8.2-19ubuntu1)。

c++ - 函数参数求值顺序

在C和C++中,是否有固定的函数参数计算顺序?我的意思是,标准怎么说?是从左到右还是从右到左?我从书中得到的信息令人困惑。函数调用是否有必要使用stackonly实现?C和C++标准对此有何规定? 最佳答案 C和C++是两种完全不同的语言;不要假设相同的规则总是适用于两者。但是,在参数评估顺序的情况下:C99:6.5.2.2Functioncalls...10Theorderofevaluationofthefunctiondesignator,theactualarguments,andsubexpressionswithinth